/* Unified site stylesheet - merged from header, footer, home, explore, login, listing-detail */
:root{
  --bg:#fffaf7;
  --bg-soft:#fff2ea;
  --surface:#ffffffcc;
  --surface-strong:#ffffff;
  --surface-2:#fffaf8;
  --white:#ffffff;
  --text:#3c2e2a;
  --text-soft:#7a6660;
  --muted:#7a6660;
  --line:#eddcd2;
  --line-soft:#f3e7df;
  --primary:#db8f7a;
  --primary-deep:#c97059;
  --primary-dark:#c97059;
  --secondary:#f4cfc2;
  --accent:#e9b9ac;
  --accent-2:#f7e0d2;
  --success:#81b29a;
  --danger:#d14a36;
  --soft-bg:rgba(255,255,255,.78);
  --shadow:0 20px 60px rgba(174,117,98,.12);
  --shadow-soft:0 14px 36px rgba(174,117,98,.08);
  --radius:24px;
  --radius-xl:32px;
  --radius-lg:22px;
  --radius-md:16px;
  --stickyTop:24px;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;scroll-behavior:smooth}
body{
  font-family:'Inter',sans-serif;
  color:var(--text);
  background:
    radial-gradient(circle at top left, rgba(244,207,194,0.6), transparent 35%),
    radial-gradient(circle at top right, rgba(233,185,172,0.45), transparent 28%),
    linear-gradient(180deg,#fffdfb 0%, var(--bg) 100%);
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
button,input,select,textarea{font:inherit}
button{cursor:pointer}
.container,.container-lg,.container-xl,.container-xxl{width:100%;max-width:1440px;margin-inline:auto}

/* Shared visual system */
.eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 14px;border-radius:999px;
  background:rgba(255,255,255,.86);border:1px solid rgba(31,41,55,.07);
  font-size:.78rem;font-weight:800;letter-spacing:.08em;text-transform:uppercase;
  color:var(--primary-deep);margin-bottom:12px;
}
.eyebrow.light{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.22);color:#fff5ef}
.hero-badge,.type-badge,.chip,.advanced-chip,.badge.plain,.trust-pill,.benefit-pill,.overlay-chip{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  padding:8px 12px;border-radius:999px;font-size:.8rem;font-weight:700;
  border:1px solid var(--line);background:linear-gradient(180deg,#fff,#fff7f3);color:var(--text);
}
.chip.active,.advanced-chip.active,.badge.feature{
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;border-color:transparent;box-shadow:0 10px 22px rgba(201,112,89,.25);
}
.hero-badge{background:#fff4ef;color:var(--primary-deep)}
.type-badge{background:rgba(255,255,255,.92);backdrop-filter:blur(8px);color:#7a4a3b;border-color:rgba(31,41,55,.06)}
.input-shell{
  display:flex;align-items:center;gap:12px;
  height:58px;padding:0 16px;border-radius:18px;
  border:1px solid var(--line);background:#fff;
  transition:border-color .25s ease,box-shadow .25s ease,background .25s ease;
}
.input-shell:focus-within{border-color:#e7a17f;box-shadow:0 0 0 4px rgba(201,112,89,.13)}
.input-shell i{color:#b07f68}
.input-shell input{width:100%;border:none;outline:none;background:transparent;color:var(--text)}
.primary-btn,.ghost-btn,.inline-btn,.view-all-btn,.soft-link-btn,.offer-btn,.slider-nav,.header-btn,.menu-toggle-btn{
  transition:transform .28s ease, box-shadow .28s ease, background .28s ease, filter .28s ease;
}
.primary-btn{
  border:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:52px;padding:0 18px;border-radius:18px;
  background:linear-gradient(135deg,var(--primary),var(--accent));
  color:#fff;font-weight:800;box-shadow:0 14px 30px rgba(201,112,89,.25);
}
.primary-btn:hover,.view-all-btn:hover,.soft-link-btn:hover,.offer-btn:hover,.slider-nav:hover,.header-btn:hover,.menu-toggle-btn:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(17,24,39,.08)}
.ghost-btn{
  display:inline-flex;align-items:center;justify-content:center;gap:8px;
  min-height:48px;padding:0 16px;border-radius:15px;
  background:#fff7f2;color:#8d5a44;border:1px solid var(--line);
}
.ghost-btn:hover{background:#fff2ea}
.listing-card,.review-card,.feature-box,.hero-card,.results-top,.filter-card,.drawer-panel,.summary-card,.booking-card,.map-card{
  background:rgba(255,255,255,.88);border:1px solid var(--line-soft);border-radius:28px;box-shadow:var(--shadow);
}
.listing-card,.review-card,.feature-box,.hero-card{transition:transform .32s ease, box-shadow .32s ease}
.listing-card:hover,.review-card:hover,.feature-box:hover,.hero-card:hover{transform:translateY(-4px);box-shadow:0 28px 62px rgba(52,76,92,.12)}
.section-head{display:flex;align-items:end;justify-content:space-between;gap:18px;margin-bottom:22px}
.compact-head{align-items:center}
.center-head{justify-content:center;text-align:center}

/* Context-aware shared layouts */
.page-shell:has(> .sticky-zone){max-width:1500px;margin:0 auto;padding:24px;display:grid;grid-template-columns:320px minmax(0,1fr);gap:24px;align-items:start}
.page-shell:has(> .topbar){max-width:1440px;margin:0 auto;padding:18px;display:flex;flex-direction:column;gap:18px}
@media (max-width:1199px){.page-shell:has(> .sticky-zone){grid-template-columns:290px minmax(0,1fr)}}
@media (max-width:991px){.page-shell:has(> .sticky-zone){grid-template-columns:1fr;padding:18px}}
@media (max-width:767px){.page-shell:has(> .sticky-zone),.page-shell:has(> .topbar){padding:14px}.section-head{margin-bottom:18px}}


/* ==== header.css ==== */
:root{
  --white:#ffffff;
  --text:#1f2937;
  --text-soft:#5b6472;
  --line:rgba(31,41,55,.08);
  --primary:#f4cfc2;
  --primary-2:#f7e1d8;
  --accent:#e9b9ac;
  --soft-bg:rgba(255,255,255,.72);
  --shadow:0 20px 60px rgba(52,76,92,.08);
  --radius-xl:24px;
  --radius-lg:18px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:'Inter',sans-serif;
  color:var(--text);
  background:radial-gradient(circle at top left, rgba(244,207,194,0.6), transparent 35%), radial-gradient(circle at top right, rgba(233,185,172,0.45), transparent 28%), linear-gradient(180deg,#fffdfb 0%, #fffaf7 100%);
  overflow-x:hidden;
}

a{color:inherit}
img{max-width:100%;display:block}
button,input{font:inherit}

.page-bg-orb{
  position:fixed;
  border-radius:50%;
  filter:blur(70px);
  opacity:.55;
  z-index:-1;
  animation:floatOrb 9s ease-in-out infinite;
}
.orb-1{width:280px;height:280px;background:rgba(244,207,194,.75);top:40px;left:-90px}
.orb-2{width:320px;height:320px;background:rgba(233,185,172,.5);top:30%;right:-120px;animation-delay:1.5s}
.orb-3{width:260px;height:260px;background:rgba(250,236,228,.9);bottom:5%;left:20%;animation-delay:3s}

@keyframes floatOrb{
  0%,100%{transform:translateY(0) translateX(0)}
  50%{transform:translateY(-18px) translateX(10px)}
}

.site-header{
  padding:18px 0 8px;
  background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,255,255,.72));
  backdrop-filter:blur(16px);
}

.header-shell{
  display:grid;
  grid-template-columns:auto minmax(320px,1fr) auto;
  align-items:center;
  gap:18px;
  padding:14px 18px;
  background:var(--soft-bg);
  border:1px solid rgba(255,255,255,.7);
  border-radius:28px;
  box-shadow:var(--shadow);
}

.brand-wrap{display:flex;align-items:center;gap:12px}
.brand-logo{
  width:48px;height:48px;border-radius:16px;display:grid;place-items:center;font-weight:800;
  color:#6f4a3d;background:linear-gradient(135deg,var(--secondary,#f4cfc2),var(--primary-2),var(--accent));
  box-shadow:0 12px 24px rgba(201,112,89,.18);
}
.brand-name{font-size:1.2rem;font-weight:800;letter-spacing:-.02em}
.brand-tag{font-size:.82rem;color:var(--text-soft)}

.address-search-wrap{
  display:flex;
  align-items:stretch;
  width:100%;
  border-radius:999px;
  overflow:hidden;
  border:1px solid var(--line);
  background:#fff;
  box-shadow:0 10px 22px rgba(174,117,98,.08);
}
.address-input-wrap{
  flex:1;
  display:flex;
  align-items:center;
  gap:10px;
  padding:0 16px;
}
.address-input-wrap i{color:#c97059;font-size:1rem}
.address-input-wrap input{
  width:100%;border:0;outline:none;background:transparent;padding:15px 0;color:var(--text)
}
.explore-btn{
  border:0;
  padding:0 18px;
  min-width:112px;
  font-weight:700;
  color:#5a3d34;
  background:linear-gradient(135deg,#f4cfc2,#f7e1d8);
  transition:transform .28s ease, filter .28s ease;
}
.explore-btn:hover{transform:translateY(-2px);filter:brightness(1.02)}

.header-right{
  display:flex;align-items:center;gap:12px
}
.header-btn,.menu-toggle-btn{
  border:1px solid var(--line);
  background:#fff;
  color:var(--text);
  text-decoration:none;
  padding:12px 16px;
  border-radius:999px;
  font-weight:600;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  transition:transform .28s ease, box-shadow .28s ease, background .28s ease;
}
.header-btn:hover,.menu-toggle-btn:hover{transform:translateY(-3px);box-shadow:0 12px 24px rgba(17,24,39,.08)}
.menu-dropdown-wrap{position:relative}
.header-dropdown-menu{
  position:absolute;
  top:calc(100% + 14px);
  right:0;
  width:320px;
  background:rgba(255,255,255,.95);
  backdrop-filter:blur(20px);
  border-radius:24px;
  border:1px solid rgba(31,41,55,.08);
  box-shadow:0 22px 60px rgba(20,35,55,.15);
  padding:18px;
  opacity:0;
  visibility:hidden;
  transform:translateY(10px);
  pointer-events:none;
  transition:.28s ease;
}
.menu-dropdown-wrap.active .header-dropdown-menu{
  opacity:1;visibility:visible;transform:translateY(0);pointer-events:auto;
}
.menu-option-list{display:grid;gap:10px}
.menu-option-btn{
  display:flex;align-items:center;gap:12px;text-decoration:none;
  padding:12px 14px;border-radius:16px;background:#fff;border:1px solid var(--line);font-weight:600;color:#25364d;
}
.menu-option-btn i{width:18px;flex:0 0 18px;text-align:center;color:#c97059;font-size:1rem}
.menu-option-btn span{flex:1 1 auto}
.menu-option-btn:hover{background:#f9fcff}
.menu-join-block{margin-top:18px;padding-top:18px;border-top:1px solid var(--line)}
.menu-join-title{font-weight:700;margin-bottom:12px}
.social-links-row{display:flex;gap:10px;flex-wrap:wrap}
.social-links-row a{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;text-decoration:none;
  background:linear-gradient(135deg,#f6fbff,#fff6f6);border:1px solid var(--line);transition:transform .28s ease;
}
.social-links-row a:hover{transform:translateY(-3px)}

@media (max-width: 1199.98px){
  .header-shell{grid-template-columns:1fr;gap:14px}
  .header-center{order:3}
  .header-right{justify-content:space-between;flex-wrap:wrap}
}

@media (max-width: 767.98px){
  .site-header{padding:14px 0 6px}
  .header-shell{padding:14px;border-radius:22px}
  .brand-name{font-size:1.05rem}
  .brand-tag{display:none}
  .address-search-wrap{border-radius:18px;overflow:hidden;gap:0;background:#fff;border:1px solid var(--line);box-shadow:0 8px 20px rgba(17,24,39,.05)}
  .address-input-wrap{background:#fff;border:none;border-radius:0;padding:0 14px;min-width:0}
  .address-input-wrap input{padding:14px 0}
  .explore-btn{border-radius:0;min-height:52px;min-width:58px;padding:0 16px}
  .header-right{gap:10px}
  .header-btn,.menu-toggle-btn{flex:1;padding:12px 14px}
  .header-dropdown-menu{width:min(320px,calc(100vw - 38px))}
}


.mobile-only-menu-btn{display:none}

@media (max-width: 767.98px){
  .header-shell{
    grid-template-columns:auto auto;
    align-items:center;
  }
  .header-left{order:1}
  .header-right{order:2;justify-self:end;justify-content:flex-end;width:auto}
  .header-center{order:3;grid-column:1/-1}
  .header-right > .header-btn{display:none}
  .menu-toggle-btn{flex:0 0 auto;min-width:auto;padding:12px 16px}
  .menu-toggle-btn span{display:none}
  .header-dropdown-menu{right:0;top:calc(100% + 12px)}
  .mobile-only-menu-btn{display:flex}
}

.explore-icon{display:none}

@media (max-width: 767.98px){
  .explore-label{display:none}
  .explore-icon{display:inline-flex;font-size:1.1rem}
}


@media (min-width: 768px){
  .header-shell{grid-template-columns:auto minmax(260px,620px) auto}
  .header-center{max-width:620px;width:100%;justify-self:center}
  .address-input-wrap input{padding:13px 0}
  .explore-btn{min-height:50px}
}


/* ==== footer.css ==== */
.site-footer{
    padding:24px 0 30px;
  }
  .footer-main-grid{
    display:grid;
    grid-template-columns:1.4fr 1fr 1fr 1fr;
    gap:24px;
    padding:28px;
    background:linear-gradient(135deg,rgba(255,255,255,.9),rgba(250,246,255,.92));
    border:1px solid rgba(31,41,55,.08);
    border-radius:28px;
    box-shadow:0 20px 60px rgba(52,76,92,.08);
  }
  .footer-brand{margin-bottom:16px}
  .footer-about{max-width:360px;color:#5b6472;line-height:1.8;margin:0}
  .footer-col h3{font-size:1rem;margin:0 0 16px;font-weight:800}
  .footer-col a{
    display:block;text-decoration:none;color:#5b6472;margin-bottom:12px;transition:transform .28s ease,color .28s ease
  }
  .footer-col a:hover{transform:translateX(4px);color:#1f2937}
  .footer-social-row{display:flex;gap:10px;flex-wrap:wrap;margin-top:8px}
  .footer-social-row a{
    width:42px;height:42px;border-radius:14px;display:grid;place-items:center;text-decoration:none;margin:0;
    background:linear-gradient(135deg,#f7fbff,#fff8f7);border:1px solid rgba(31,41,55,.08)
  }
  .footer-bottom-bar{
    text-align:center;padding:18px 10px 0;color:#6b7280;font-size:.95rem
  }
  
  @media (max-width: 991.98px){
    .footer-main-grid{grid-template-columns:1fr 1fr;gap:22px}
  }
  
  @media (max-width: 575.98px){
    .footer-main-grid{grid-template-columns:1fr;padding:22px;border-radius:22px}
  }


/* ==== home.css ==== */
.container-xxl{max-width:1440px}
main section{padding:26px 0}
.compact-head{align-items:center}
.center-head{justify-content:center;text-align:center}
.section-right-group{display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.eyebrow.light{background:rgba(255,255,255,.15);border-color:rgba(255,255,255,.18);color:#ecf7ff}
.hero-title,.section-title-lg,.section-title-sm{
  margin:0;line-height:1.16;letter-spacing:-.03em;color:#162536
}
.hero-title{font-size:clamp(2rem,4vw,3.45rem);max-width:860px}
.section-title-lg{font-size:clamp(1.55rem,3vw,2.4rem)}
.section-title-sm{font-size:clamp(1.05rem,2vw,1.35rem)}

.slider-actions{display:flex;gap:10px}
.slider-nav,.view-all-btn,.soft-link-btn,.offer-btn{
  border:none;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:8px;
  transition:transform .28s ease, box-shadow .28s ease, filter .28s ease
}
.slider-nav{
  width:48px;height:48px;border-radius:16px;background:rgba(255,255,255,.94);border:1px solid rgba(31,41,55,.08);box-shadow:0 12px 24px rgba(17,24,39,.07);color:#25364d
}
.slider-nav:hover,.view-all-btn:hover,.soft-link-btn:hover,.offer-btn:hover{transform:translateY(-3px);box-shadow:0 14px 28px rgba(17,24,39,.08)}
.view-all-btn,.soft-link-btn,.offer-btn{
  padding:12px 18px;border-radius:999px;background:linear-gradient(135deg,#fff4ef,#f7e1d8);color:#5a3d34;font-weight:700
}

.category-strip-section{padding-top:12px}
.category-strip-wrap{
  background:rgba(255,255,255,.78);border:1px solid rgba(31,41,55,.08);border-radius:28px;padding:18px;box-shadow:0 18px 50px rgba(174,117,98,.10);position:relative;overflow:visible
}
.category-track{
  display:grid;
  grid-auto-flow:column;
  grid-auto-columns:calc((100% - (14px * 3)) / 4);
  gap:14px;
  overflow-x:auto;
  overflow-y:visible;
  scroll-behavior:smooth;
  padding-bottom:4px;
  scrollbar-width:none;
}
.category-track::-webkit-scrollbar{display:none}
.category-item{
  position:relative;
  background:linear-gradient(180deg,rgba(255,255,255,.96),rgba(255,249,245,.98));border:1px solid rgba(31,41,55,.08);border-radius:20px;padding:10px;transition:transform .28s ease, box-shadow .28s ease
}
.category-item:hover{transform:translateY(-4px);box-shadow:0 16px 34px rgba(17,24,39,.08)}
.category-toggle{
  width:100%;border:0;background:transparent;padding:8px;display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;text-align:left;font-weight:700;color:#1f2937
}
.category-icon{
  width:42px;height:42px;border-radius:14px;display:grid;place-items:center;background:linear-gradient(135deg,#fff4ef,#f7e1d8);color:#c97059;font-size:1.1rem
}
.category-name{font-size:.96rem;line-height:1.3}
.category-arrow{transition:transform .28s ease;color:#6b7280}
.category-item.active .category-arrow{transform:rotate(180deg)}
.subcategory-panel{display:none}
.floating-subcategory-panel{position:absolute;left:18px;right:18px;top:calc(100% + 12px);display:none;z-index:40;max-height:200px;overflow:auto;padding:16px;border-radius:22px;background:rgba(255,255,255,.98);border:1px solid rgba(31,41,55,.08);box-shadow:0 22px 60px rgba(174,117,98,.14)}
.floating-subcategory-panel.open{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:10px}
.floating-subcategory-panel a{text-decoration:none;color:#677284;font-size:.92rem;padding:10px 12px;border-radius:14px;background:#fff8f4;border:1px solid rgba(31,41,55,.05)}
.floating-subcategory-panel a:hover{color:#1f2937;background:#fff2ea}

.custom-slider{overflow:hidden;position:relative}
.slider-track{display:flex;transition:transform .38s ease}
.slide-card{flex:0 0 auto;padding:10px}
.hero-card,.listing-card,.feature-box,.review-card{
  background:rgba(255,255,255,.82);border:1px solid rgba(31,41,55,.08);border-radius:28px;box-shadow:0 20px 55px rgba(52,76,92,.08);overflow:hidden
}
.hero-card,.listing-card,.feature-box,.review-card{transition:transform .32s ease, box-shadow .32s ease}
.hero-card:hover,.listing-card:hover,.feature-box:hover,.review-card:hover{transform:translateY(-6px);box-shadow:0 28px 62px rgba(52,76,92,.12)}
.hero-card img{width:100%;height:320px;object-fit:cover}
.hero-card-content{padding:22px}
.hero-card-content h3{font-size:1.45rem;line-height:1.25;margin:0 0 12px}
.hero-card-content p{color:#5b6472;line-height:1.75;margin:0 0 18px}

.listing-thumb-wrap{position:relative}
.listing-thumb-wrap img{width:100%;height:240px;object-fit:cover}
.listing-card-body{padding:18px}
.listing-head-row{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start;gap:14px}
.listing-title-block h3{font-size:1.1rem;margin:0 0 8px;line-height:1.3}
.listing-title-block p,.listing-title-block span{margin:0;color:#667080;font-size:.93rem;line-height:1.65}
.listing-rating{
  min-width:max-content;display:inline-flex;align-items:center;gap:6px;padding:9px 12px;border-radius:14px;background:#fff4ef;color:#7a4a3b;font-size:.9rem;font-weight:700;justify-self:end;margin-top:-4px
}
.listing-rating i,.review-stars i{color:#f6b93b}
.compact-rating{padding:9px 10px}
.featured-head-row{align-items:center}

.alt-section .listing-card,.alt-section .feature-box,.alt-section .review-card{background:linear-gradient(180deg,#ffffff,#fcfeff)}

.offer-banner-card{
  position:relative;min-height:320px;border-radius:34px;overflow:hidden;
  background:url('../images/offer-bg.jpg') center center/cover no-repeat;box-shadow:0 24px 65px rgba(31,41,55,.12)
}
.offer-banner-overlay{
  position:absolute;inset:0;background:linear-gradient(90deg,rgba(255,255,255,.08),rgba(255,255,255,.04) 38%,rgba(32,26,58,.34) 100%);backdrop-filter:blur(7px)
}
.offer-banner-card.has-copy .offer-banner-overlay{background:linear-gradient(90deg,rgba(255,255,255,.18) 0%,rgba(255,255,255,.08) 34%,rgba(34,25,64,.52) 62%,rgba(24,18,44,.72) 100%)}
.offer-image-only .blur-heavy{backdrop-filter:blur(7px)}
.offer-banner-content{position:relative;z-index:2;max-width:min(460px,42%);padding:44px 44px 44px 0;color:#fff;margin-left:auto;margin-right:36px;text-align:left;display:flex;flex-direction:column;justify-content:center;min-height:320px}
.offer-banner-content h2{font-size:clamp(1.55rem,2.6vw,2.45rem);margin:0 0 14px;line-height:1.18;letter-spacing:-.03em}
.offer-banner-content p{margin:0;color:#edf4fb;line-height:1.72;font-size:1rem}
.offer-btn{background:linear-gradient(135deg,#ffffff,#def6ff)}

.feature-box{padding:28px;height:100%}
.feature-icon{
  width:64px;height:64px;border-radius:20px;display:grid;place-items:center;margin-bottom:18px;font-size:1.45rem;color:#32556f;background:linear-gradient(135deg,#fff4ef,#f7e1d8)
}
.feature-box h3{margin:0 0 12px;font-size:1.3rem}
.feature-box p{margin:0;color:#5b6472;line-height:1.8}
.review-top-row{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:20px}
.review-top-row img{width:58px;height:58px;border-radius:18px;object-fit:cover}
.review-stars{display:flex;gap:3px;font-size:.95rem}
.review-copy{margin:0 0 18px;color:#5b6472;line-height:1.9}
@media (max-width: 991.98px){
  main section{padding:22px 0}
.section-right-group{width:100%;justify-content:space-between}
  .category-track{grid-auto-columns:calc((100% - (14px * 3)) / 4)}
  .hero-card img{height:280px}
}

@media (max-width: 767.98px){
.slider-actions{align-self:flex-start}
  .slider-nav{width:44px;height:44px;border-radius:14px}
  .category-strip-wrap,.hero-card,.listing-card,.feature-box,.review-card,.offer-banner-card{border-radius:22px}
  .category-track{grid-auto-columns:calc((100% - 14px) / 2)}
  .subcategory-panel{left:0;width:min(260px,calc(100vw - 44px));max-height:200px}
  .hero-card img{height:240px}
  .listing-thumb-wrap img{height:210px}
  .listing-head-row{grid-template-columns:1fr}
  .offer-banner-card{min-height:240px}
  .offer-banner-content{padding:30px 24px}
}

.hero-image-slider .slider-track{align-items:stretch}
.image-only-card{padding:10px}
.image-only-card img{height:420px;border-radius:28px}
.hero-card.image-only-card{background:transparent;border:none;box-shadow:none;overflow:visible}
.hero-card.image-only-card:hover{transform:translateY(-4px);box-shadow:none}
.overlay-slider-actions{
  position:absolute;
  left:0;
  right:0;
  top:50%;
  transform:translateY(-50%);
  display:flex;
  justify-content:space-between;
  padding:0 12px;
  pointer-events:none;
  z-index:5;
}
.overlay-slider-actions .slider-nav{pointer-events:auto;background:rgba(255,255,255,.96)}
.slider-nav.is-disabled{opacity:.38;filter:grayscale(.15);pointer-events:none}
.hero-image-slider .overlay-slider-actions{padding:0 18px}

.nearby-card .listing-title-block p,
#mostBookedSlider .listing-title-block p,
#newSlider .listing-title-block p{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.nearby-card .listing-card-body{padding:18px 18px 16px}

@media (max-width: 767.98px){
  .overlay-slider-actions{padding:0 8px}
  .image-only-card img{height:260px;border-radius:22px}
  .nearby-card .listing-title-block p,
  #mostBookedSlider .listing-title-block p,
  #newSlider .listing-title-block p{white-space:normal;overflow:visible;text-overflow:unset}
}

.listing-title-block p{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.listing-title-block span{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
.listing-rating{margin-top:-8px;transform:translateX(2px)}
.review-card img{object-fit:cover}
.compact-head .slider-actions{margin-left:auto}
.category-overlay-actions{padding:0 10px;top:50%;transform:translateY(-50%)}
.category-strip-wrap{position:relative;padding-bottom:18px;overflow:visible}
.category-item.active{box-shadow:0 14px 32px rgba(89,73,140,.12)}
.offer-banner-card.has-copy{min-height:320px}
@media (max-width: 991.98px){.category-track{grid-auto-columns:calc((100% - (14px * 2)) / 3)} .floating-subcategory-panel{left:12px;right:12px}}
@media (max-width: 767.98px){.category-track{grid-auto-columns:100%} .floating-subcategory-panel{left:8px;right:8px;grid-template-columns:1fr;width:auto} .offer-banner-card.has-copy{min-height:300px;background-position:center} .offer-banner-content{padding:24px 20px;max-width:100%;margin:0;background:linear-gradient(180deg,rgba(25,19,48,.08),rgba(25,19,48,.68));position:absolute;left:0;right:0;bottom:0;border-top-left-radius:22px;border-top-right-radius:22px;min-height:auto}}


.category-track{scroll-snap-type:x mandatory;}
.category-item{scroll-snap-align:start;}
@media (max-width: 767.98px){
  .category-strip-wrap{padding:14px 12px 18px;}
  .category-track{grid-auto-columns:100%;gap:12px;padding:0 2px 4px;}
  .category-item{min-height:84px;}
  .category-toggle{padding:10px 8px;}
  .category-overlay-actions{padding:0 4px;}
}


/* ==== explore.css ==== */
.sticky-zone{position:sticky;top:var(--stickyTop);z-index:20}
.filter-card,.results-top,.listing-card,.drawer-panel{background:var(--surface-strong);border:1px solid var(--line-soft);box-shadow:var(--shadow);border-radius:var(--radius)}
.desktop-sidebar{height:calc(100vh - 48px)}
.filter-card{padding:24px;height:calc(100vh - 48px);display:flex;flex-direction:column;overflow:hidden}
.filter-head,.results-toolbar,.advanced-head,.drawer-head,.drawer-footer-actions{display:flex;align-items:center;justify-content:space-between;gap:16px}
.filter-head h2,.advanced-head h3{margin:0;font-size:1.2rem}
.clear-btn,.advanced-btn,.drawer-clear,.drawer-apply,.step-btn,.slider-btn,.view-btn{border:none;transition:.25s ease}
.clear-btn{background:#fff4ef;color:var(--primary-deep);padding:10px 14px;border-radius:14px;font-weight:700}
.clear-btn:hover,.advanced-btn:hover,.drawer-clear:hover,.drawer-apply:hover,.step-btn:hover,.slider-btn:hover,.view-btn:hover{transform:translateY(-2px)}
.filter-group{padding-top:18px;margin-top:18px;border-top:1px solid var(--line-soft)}
.filter-group:first-of-type{padding-top:0;margin-top:20px;border-top:none}
.filter-group h3{margin:0 0 12px;font-size:1rem}
.filter-group p{margin:4px 0 0;color:var(--muted);font-size:.88rem}
.chip-grid,.advanced-chip-wrap{display:flex;flex-wrap:wrap;gap:10px}
.range-row{display:grid;grid-template-columns:48px 1fr 48px;gap:12px;align-items:center}
.step-btn{height:48px;border-radius:14px;background:#fff4ef;color:var(--primary-deep);font-size:1.4rem;font-weight:700}
.range-wrap{display:flex;flex-direction:column;gap:10px}
.range-wrap input[type="range"]{width:100%;accent-color:var(--primary)}
.range-value{font-weight:700;color:var(--primary-deep)}
.filter-select{width:100%;height:52px;border-radius:16px;border:1px solid var(--line);padding:0 14px;background:#fffaf8;color:var(--text)}
.switch-group{display:flex;flex-direction:column;gap:14px}
.switch-line{display:flex;justify-content:space-between;gap:16px;align-items:center;padding:14px;border:1px solid var(--line-soft);border-radius:18px;background:#fffaf8}
.switch{position:relative;display:inline-block;width:54px;height:30px}
.switch input{opacity:0;width:0;height:0}
.slider-switch{position:absolute;inset:0;background:#e6d4cc;border-radius:999px;transition:.2s}
.slider-switch:before{content:'';position:absolute;height:22px;width:22px;left:4px;top:4px;background:white;border-radius:50%;transition:.2s;box-shadow:0 3px 8px rgba(0,0,0,.15)}
.switch input:checked + .slider-switch{background:linear-gradient(135deg,var(--primary),var(--accent))}
.switch input:checked + .slider-switch:before{transform:translateX(24px)}
.content-area{min-width:0}
.results-top{padding:18px 20px;margin-bottom:22px;backdrop-filter:blur(8px)}
.results-toolbar{min-height:56px}
.advanced-btn{background:linear-gradient(135deg,var(--primary),var(--accent));color:white;padding:13px 18px;border-radius:16px;font-weight:700;display:inline-flex;align-items:center;gap:10px;box-shadow:0 10px 24px rgba(201,112,89,.25)}
.results-count{font-weight:800;color:var(--primary-deep);font-size:1.05rem}
.advanced-panel{margin-top:16px;padding-top:16px;border-top:1px solid var(--line-soft)}
.advanced-panel.hidden{display:none}
.advanced-head{align-items:flex-start;flex-direction:column}
.advanced-head p{margin:0;color:var(--muted)}
.listing-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:22px;padding-bottom:60px}
.image-slider{position:relative;height:250px;overflow:hidden;background:#f3e5df}
.image-slider img{width:100%;height:100%;object-fit:cover;display:block}
.image-track{display:flex;height:100%;transition:transform .35s ease}
.slide{min-width:100%;height:100%}
.slider-btn{position:absolute;top:50%;transform:translateY(-50%);z-index:3;width:42px;height:42px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--primary-deep);font-size:1rem;box-shadow:0 10px 18px rgba(0,0,0,.14)}
.slider-btn.prev{left:12px}.slider-btn.next{right:12px}
.slider-btn.disabled{opacity:.35;pointer-events:none;filter:blur(1px)}
.card-body{padding:18px}
.card-head{display:flex;gap:12px;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.card-title{margin:0;font-size:1.08rem;line-height:1.35}
.rating-pill{white-space:nowrap;background:#f6efe8;padding:8px 10px;border-radius:999px;font-weight:800;color:#7b5c53;font-size:.92rem}
.address{margin:0 0 12px;color:var(--muted);line-height:1.5}
.price-row{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-top:8px;padding-top:12px;border-top:1px solid var(--line-soft)}
.starting-price strong{color:var(--primary-deep)}
.view-btn{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:12px 16px;border-radius:14px;font-weight:700}
.empty-state{grid-column:1/-1;background:#fff;padding:40px;border-radius:24px;border:1px dashed var(--line);text-align:center;color:var(--muted)}
.mobile-filter-btn,.mobile-drawer{display:none}
.drawer-panel{position:absolute;left:0;right:0;bottom:0;border-bottom-left-radius:0;border-bottom-right-radius:0;max-height:88vh;display:flex;flex-direction:column}
.drawer-head{padding:20px;border-bottom:1px solid var(--line-soft)}
.drawer-body{padding:18px 20px 8px;overflow:auto}
.drawer-close{border:none;background:#fff4ef;color:var(--primary-deep);width:42px;height:42px;border-radius:12px}
.drawer-footer{padding:16px 20px;border-top:1px solid var(--line-soft);display:flex;flex-direction:column;gap:14px;align-items:stretch}
.drawer-clear,.drawer-apply,.drawer-advanced{height:50px;padding:0 18px;border-radius:16px;font-weight:800;border:none}
.drawer-clear{background:#fff4ef;color:var(--primary-deep)}
.drawer-advanced{background:#fff6f1;color:var(--primary-deep)}
.drawer-apply{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff}
.drawer-backdrop{position:absolute;inset:0;background:rgba(40,27,22,.42);backdrop-filter:blur(2px)}
.mobile-drawer.active{display:block;position:fixed;inset:0;z-index:999}
@media (max-width:1200px){
}
@media (max-width:991px){
.desktop-sidebar{display:none}
  .results-top{position:sticky;top:14px}
  .listing-grid{grid-template-columns:1fr}
  .mobile-filter-btn{display:inline-flex;align-items:center;gap:10px;justify-content:center;position:fixed;left:50%;transform:translateX(-50%);bottom:18px;z-index:50;border:none;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;padding:14px 18px;border-radius:999px;box-shadow:0 18px 34px rgba(201,112,89,.28);font-weight:800}
}
@media (max-width:767px){
.results-top{padding:14px 16px}
  .results-toolbar{flex-wrap:wrap;justify-content:flex-start}
  .advanced-btn{display:none}
  .results-count{font-size:1rem}
  .image-slider{height:220px}
  .card-head{align-items:center}
  .price-row{flex-direction:column;align-items:flex-start}
  .view-btn{width:100%}
}

.filter-head{position:sticky;top:0;z-index:3;background:var(--surface-strong);padding-bottom:16px;border-bottom:1px solid var(--line-soft)}
.filter-scroll-area{overflow:auto;flex:1 1 auto;padding-right:6px;padding-bottom:4px}
.filter-scroll-area::-webkit-scrollbar,.drawer-body::-webkit-scrollbar,.mobile-advanced-panel::-webkit-scrollbar{width:8px}
.filter-scroll-area::-webkit-scrollbar-thumb,.drawer-body::-webkit-scrollbar-thumb,.mobile-advanced-panel::-webkit-scrollbar-thumb{background:#e5c9be;border-radius:999px}

.mobile-advanced-panel{display:flex;flex-wrap:wrap;gap:10px;max-height:180px;overflow:auto;background:#fffaf8;border:1px solid var(--line-soft);border-radius:18px;padding:14px}
.mobile-advanced-panel.hidden{display:none}
.mobile-advanced-panel .advanced-chip{font-size:.92rem}

.empty-inline{color:var(--muted);font-size:.92rem;line-height:1.5;padding:8px 2px}


.drawer-results-count{display:none;font-weight:800;color:var(--primary-deep);padding:0 24px 12px;font-size:1rem}
@media (max-width: 991px){
  .results-toolbar .results-count{display:none}
  .drawer-results-count{display:block}
}


/* ==== login.css ==== */
.login-page{
  min-height:100vh;
  position:relative;
  overflow:hidden;
  padding:28px;
}
.ambient{
  position:absolute;
  border-radius:50%;
  filter:blur(14px);
  opacity:.55;
  pointer-events:none;
}
.ambient-one{
  width:280px;height:280px;
  background:rgba(255,197,163,.55);
  top:-60px;left:-70px;
}
.ambient-two{
  width:360px;height:360px;
  background:rgba(255,228,212,.7);
  right:-120px;bottom:-90px;
}

.login-wrap{
  position:relative;
  z-index:2;
  max-width:1280px;
  margin:0 auto;
  min-height:calc(100vh - 56px);
  display:grid;
  grid-template-columns:1.08fr .92fr;
  gap:26px;
  align-items:stretch;
}
.hero-panel,
.form-panel{
  background:rgba(255,255,255,.82);
  backdrop-filter: blur(10px);
  border:1px solid rgba(239,217,206,.85);
  box-shadow:var(--shadow);
}
.hero-panel{
  border-radius:var(--radius-xl);
  padding:34px;
  display:flex;
  flex-direction:column;
  gap:24px;
  position:relative;
}
.hero-panel::after{
  content:"";
  position:absolute;
  inset:auto 22px 22px auto;
  width:110px;height:110px;
  border-radius:28px;
  background:linear-gradient(135deg, rgba(255,255,255,.45), rgba(255,206,176,.58));
  opacity:.55;
}
.hero-badge,
.trust-pill,
.benefit-pill,
.overlay-chip{
  display:inline-flex;
  align-items:center;
  gap:10px;
  padding:10px 14px;
  border-radius:999px;
  background:var(--surface-2);
  border:1px solid var(--line);
  color:#9a5c3f;
  font-size:13px;
  font-weight:700;
}
.hero-copy h1,
.form-top h2{
  margin:0;
  line-height:1.08;
}
.hero-copy h1{
  font-size:clamp(34px,4.3vw,58px);
  max-width:12ch;
}
.lead,.subtext{
  margin:12px 0 0;
  color:var(--muted);
  line-height:1.7;
  max-width:62ch;
}
.hero-card-stack{
  position:relative;
  display:grid;
  grid-template-columns:minmax(0,1fr);
}
.hero-image-shell{
  position:relative;
  border-radius:30px;
  overflow:hidden;
  min-height:420px;
  box-shadow:var(--shadow-soft);
}
.hero-image-shell img{
  width:100%;height:100%;object-fit:cover;display:block;
}
.hero-image-overlay{
  position:absolute;
  left:18px;right:18px;bottom:18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.overlay-chip{background:rgba(255,255,255,.9);backdrop-filter:blur(6px)}
.mini-card{
  position:absolute;
  z-index:2;
  max-width:250px;
  background:rgba(255,255,255,.94);
  border:1px solid rgba(239,217,206,.9);
  border-radius:24px;
  padding:16px;
  box-shadow:var(--shadow-soft);
  display:flex;
  align-items:flex-start;
  gap:14px;
}
.mini-card .icon{
  width:44px;height:44px;border-radius:14px;
  display:grid;place-items:center;
  background:linear-gradient(135deg, #ffe0cf, #fff7f2);
  color:var(--primary-dark);
  flex-shrink:0;
}
.mini-card strong{display:block;margin-bottom:4px}
.mini-card p{margin:0;color:var(--muted);font-size:13px;line-height:1.55}
.mini-card-left{left:-8px;bottom:24px}
.mini-card-right{right:-8px;top:20px}
.feature-strip{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
}
.feature-item{
  padding:16px 14px;
  border-radius:20px;
  background:linear-gradient(180deg, #fffaf8, #fff4ee);
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:#8d5d49;
  font-weight:700;
}
.feature-item i{color:var(--primary-dark)}

.form-panel{
  border-radius:var(--radius-xl);
  padding:32px;
  display:flex;
  flex-direction:column;
  justify-content:center;
}
.form-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:24px;
}
.form-top h2{font-size:clamp(28px,3vw,40px)}
.progress-steps{
  display:none !important;
}
.progress-step{
  background:#fff8f3;
  border:1px solid var(--line);
  border-radius:20px;
  padding:14px 12px;
  display:flex;
  align-items:center;
  gap:10px;
  color:#a08477;
}
.progress-step span{
  width:32px;height:32px;border-radius:50%;display:grid;place-items:center;
  background:#fff;border:1px solid var(--line);font-weight:800;
}
.progress-step small{font-size:13px;font-weight:700}
.progress-step.active{
  background:linear-gradient(135deg, #fff2e9, #ffe6d7);
  color:#8b5036;
  border-color:#efc4b0;
}
.progress-step.active span{
  background:var(--primary);
  color:#fff;
  border-color:var(--primary);
}

.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field-group label{
  display:block;
  margin-bottom:9px;
  font-size:14px;
  font-weight:700;
}
.phone-shell{gap:0;padding-left:0}
.country-code{
  height:100%;
  display:flex;align-items:center;
  padding:0 16px 0 18px;
  border-right:1px solid var(--line);
  color:#8f6a58;font-weight:700;
}
.phone-shell input{padding-left:14px}
.benefit-row{display:flex;gap:10px;flex-wrap:wrap;margin:18px 0}
.checkbox-line{
  display:flex;align-items:flex-start;gap:12px;
  padding:14px 16px;
  background:#fffaf7;
  border:1px solid var(--line);
  border-radius:18px;
  color:var(--muted);
  line-height:1.6;
}
.checkbox-line input{margin-top:4px;accent-color:var(--primary)}
.checkbox-line a{color:var(--primary-dark);font-weight:700}
.error-text{
  min-height:18px;
  margin:8px 4px 0;
  font-size:12px;
  color:#d14a36;
}
.step-panel{
  display:none;
}

.step-panel.active{
  display:block;
}

.step-panel.step-enter .field-grid,
.step-panel.step-enter .field-group,
.step-panel.step-enter .otp-status,
.step-panel.step-enter .category-step-head,
.step-panel.step-enter .category-list,
.step-panel.step-enter .otp-boxes,
.step-panel.step-enter .otp-hint-row,
.step-panel.step-enter .success-card,
.step-panel.step-enter .step-actions{
  animation:stepContentSlideRight .32s ease both;
}

#loginForm{
  position:relative;
  overflow:hidden;
  min-height:320px;
}

@keyframes stepContentSlideRight{
  from{
    opacity:0;
    transform:translateX(26px);
  }
  to{
    opacity:1;
    transform:translateX(0);
  }
}

.otp-status{
  padding:18px;
  border-radius:22px;
  background:linear-gradient(180deg,#fffaf7,#fff3eb);
  border:1px solid var(--line);
  display:flex;justify-content:space-between;gap:14px;align-items:center;
}
.otp-status p{margin:4px 0 0;color:var(--muted)}
.otp-boxes{
  display:grid;
  grid-template-columns:repeat(4, minmax(0, 76px));
  justify-content:start;
  gap:14px;
  margin:22px 0 8px;
}
.otp-input{
  width:100%;height:72px;border-radius:20px;border:1px solid var(--line);
  text-align:center;font-size:28px;font-weight:800;outline:none;background:#fff;
}
.otp-input:focus{border-color:#e7a17f;box-shadow:0 0 0 4px rgba(241,139,104,.13)}
.otp-hint-row{
  display:flex;justify-content:space-between;gap:10px;align-items:center;
  color:var(--muted);font-size:14px;margin-bottom:18px;
}
.step-actions{display:flex;gap:12px}
.step-actions .ghost-btn,.step-actions .primary-btn{width:100%}
.success-card{
  text-align:center;
  padding:18px 6px 4px;
}
.success-icon{
  width:88px;height:88px;border-radius:28px;
  display:grid;place-items:center;margin:0 auto 18px;
  background:linear-gradient(135deg, #ffe4d4, #fff7f2);
  color:var(--primary-dark);font-size:38px;
}
.success-card h3{margin:0 0 8px;font-size:30px}
.success-card p{margin:0;color:var(--muted)}
.success-meta{
  margin:20px 0 24px;
  display:flex;gap:10px;justify-content:center;flex-wrap:wrap;
}
.success-meta span{
  padding:10px 14px;border-radius:999px;background:#fff8f2;border:1px solid var(--line);font-weight:700;color:#8d5d49;
}
.category-step-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  flex-wrap:wrap;
  margin:18px 0 16px;
}

.category-step-note{
  margin:0;
  color:var(--muted);
  font-size:14px;
}

.category-count-wrap{
  display:flex;
  align-items:center;
  gap:10px;
}

.category-count-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:10px 14px;
  border-radius:999px;
  background:#fff4ee;
  border:1px solid var(--line);
  color:#8d5a44;
  font-size:13px;
  font-weight:800;
}

.category-list{
  display:grid;
  grid-template-columns:repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:8px;
}

.category-card{
  width:100%;
  min-height:72px;
  border:1px solid var(--line);
  border-radius:20px;
  background:linear-gradient(180deg,#fff,#fff8f4);
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:14px;
  text-align:left;
  color:var(--text);
  font-weight:700;
  transition:transform .25s ease, box-shadow .25s ease, border-color .25s ease, background .25s ease;
}

.category-card:hover{
  transform:translateY(-2px);
  box-shadow:0 14px 28px rgba(17,24,39,.06);
}

.category-card.active{
  background:linear-gradient(135deg,#fff2e9,#ffe6d7);
  border-color:#efc4b0;
  color:#8b5036;
}

.category-card-check{
  width:34px;
  height:34px;
  border-radius:50%;
  border:1px solid var(--line);
  background:#fff;
  display:grid;
  place-items:center;
  flex:0 0 34px;
  color:transparent;
}

.category-card.active .category-card-check{
  background:var(--primary);
  border-color:var(--primary);
  color:#fff;
}

.category-card-title{
  flex:1 1 auto;
  min-width:0;
}

.category-loading{
  padding:18px;
  border-radius:18px;
  border:1px solid var(--line);
  background:#fffaf7;
  color:var(--muted);
}

@media (max-width: 767px){
  .category-list{
    grid-template-columns:1fr;
  }
}
@media (max-width: 1180px){
  .login-wrap{grid-template-columns:1fr;max-width:860px}
  .hero-copy h1{max-width:14ch}
  .mini-card-left{left:12px}
  .mini-card-right{right:12px}
}
@media (max-width: 767px){
  .login-page{padding:16px}
  .login-wrap{gap:18px;min-height:auto}
  .hero-panel,.form-panel{padding:22px;border-radius:24px}
  .hero-copy h1{font-size:34px;max-width:none}
  .hero-image-shell{min-height:300px}
  .mini-card{position:static;max-width:none;margin-top:14px}
  .hero-card-stack{display:flex;flex-direction:column}
  .feature-strip{grid-template-columns:repeat(2,1fr)}
  .form-top{flex-direction:column}
  .field-grid{grid-template-columns:1fr}
  .otp-boxes{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
  .otp-input{height:64px}
}
@media (max-width: 520px){
  .progress-steps{display:none !important;}
  .progress-step{padding:12px 10px;border-radius:16px}
  .progress-step span{width:28px;height:28px;font-size:13px}
  .progress-step small{font-size:12px}
  .benefit-row{flex-direction:column}
  .feature-strip{grid-template-columns:1fr 1fr}
  .otp-status{flex-direction:column;align-items:flex-start}
  .otp-hint-row{flex-direction:column;align-items:flex-start}
  .step-actions{flex-direction:column}
}


/* ==== listing-detail.css ==== */
button,input,textarea{font:inherit}
img{display:block;max-width:100%}
  .hidden{display:none!important}
.card{background:rgba(255,255,255,.88);backdrop-filter:blur(10px);border:1px solid rgba(237,220,210,.9);border-radius:var(--radius);box-shadow:var(--shadow)}
.topbar{display:flex;justify-content:space-between;gap:18px;padding:22px}
  .title-block h1{margin:0 0 10px;font-size:clamp(1.6rem,2.6vw,2.3rem)}
  .title-meta{display:flex;flex-wrap:wrap;gap:10px 14px;color:var(--muted);font-size:.93rem;margin-bottom:10px}
  .title-meta i{color:#f0a53a}
  .type-pill{padding:8px 12px;border-radius:999px;background:#fff3ee;color:var(--primary-deep);font-weight:800}
  .title-block p{margin:0;color:var(--muted);line-height:1.6}
  .top-actions{display:flex;align-items:flex-start;gap:12px;flex-wrap:wrap}
  .ghost-btn,.mini-btn,.secondary-btn,.circle-btn,.hero-nav,.gallery-nav,.sheet-close{transition:.25s ease}
  .ghost-btn,.mini-btn,.secondary-btn{height:46px;padding:0 16px;border-radius:16px;background:#fff7f2;color:var(--text);border:1px solid var(--line-soft);font-weight:700}
  .ghost-btn:hover,.mini-btn:hover,.secondary-btn:hover{transform:translateY(-2px);background:#fff0e9}
  .hero{padding:14px;position:relative;overflow:hidden}
  .hero-window{overflow:hidden;border-radius:22px}
  .hero-track{display:flex;gap:14px;transition:transform .45s ease}
  .hero-slide{min-width:calc(50% - 7px);position:relative;border-radius:22px;overflow:hidden;height:360px;cursor:pointer}
  .hero-slide img{width:100%;height:100%;object-fit:cover}
  .hero-slide::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(10,10,10,.08),rgba(10,10,10,.22))}
  .hero-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.92);color:var(--primary-deep);box-shadow:0 10px 24px rgba(0,0,0,.12);z-index:2}
  .hero-nav:hover,.circle-btn:hover,.gallery-nav:hover{transform:translateY(-50%) scale(1.04)}
  .hero-nav.prev{left:24px}.hero-nav.next{right:24px}
  .hero-thumbs{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;padding-top:14px}
  .hero-thumb{width:74px;height:54px;border-radius:14px;overflow:hidden;border:2px solid transparent;opacity:.7;cursor:pointer}
  .hero-thumb.active{border-color:var(--primary);opacity:1}
  .hero-thumb img{width:100%;height:100%;object-fit:cover}
  .desktop-layout{display:grid;grid-template-columns:280px minmax(0,1fr) 320px;gap:18px;align-items:start}
  .sidebar-left,.summary-card,.booking-card,.map-card{overflow:hidden}
  .sidebar-left{position:sticky;top:18px;height:calc(100vh - 36px)}
  .sidebar-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding:18px 18px 14px;background:linear-gradient(180deg,#fff 0%,#fffaf7 100%);border-bottom:1px solid var(--line-soft);z-index:2}
  .sidebar-inner{height:calc(100% - 88px);overflow:auto;padding:16px 18px 18px}
  .sidebar-inner::-webkit-scrollbar,.services-scroll::-webkit-scrollbar,.cart-list::-webkit-scrollbar,.sheet-body::-webkit-scrollbar{width:10px}
  .sidebar-inner::-webkit-scrollbar-thumb,.services-scroll::-webkit-scrollbar-thumb,.cart-list::-webkit-scrollbar-thumb,.sheet-body::-webkit-scrollbar-thumb{background:#e8c9bc;border-radius:999px}
  .filter-block+.filter-block{margin-top:18px}
  .filter-block h3{margin:0 0 12px;font-size:1rem}
  .chips{display:flex;flex-wrap:wrap;gap:10px}
  .chip,.subcat-btn,.tab-btn{border:1px solid var(--line-soft);background:#fffaf8;color:var(--text)}
  .chip{padding:11px 14px;border-radius:999px;font-weight:700}
  .chip.active,.subcat-btn.active,.tab-btn.active{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent;box-shadow:0 10px 22px rgba(201,112,89,.2)}
  .subcat-list{display:flex;flex-direction:column;gap:10px}
  .subcat-btn{padding:13px 14px;border-radius:16px;text-align:left;font-weight:700}
  .center-column{min-width:0}
  .service-browser{display:grid;grid-template-columns:220px minmax(0,1fr);gap:18px;padding:18px;max-height:560px}
  .service-visual{border-radius:22px;overflow:hidden;min-height:220px;background:#f5eae3;position:sticky;top:0;align-self:start}
  .service-visual img{width:100%;height:100%;min-height:260px;object-fit:cover}
  .service-content{min-width:0;display:flex;flex-direction:column}
  .service-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
  .service-head h2{margin:.2rem 0 0}
  .service-count{padding:10px 12px;border-radius:999px;background:#fff3ee;color:var(--primary-deep);font-weight:800;white-space:nowrap}
  .services-scroll{overflow:auto;padding-top:14px;display:flex;flex-direction:column;gap:14px;max-height:468px}
  .service-item{display:grid;grid-template-columns:84px minmax(0,1fr) auto;gap:14px;align-items:center;padding:14px;border:1px solid var(--line-soft);background:linear-gradient(180deg,#fff,#fffaf8);border-radius:20px}
  .service-item img{width:84px;height:84px;border-radius:18px;object-fit:cover}
  .service-main h4{margin:0 0 8px;font-size:1rem}
  .service-main .meta{display:flex;flex-wrap:wrap;gap:12px;color:var(--muted);font-size:.9rem}
  .price-line{display:flex;flex-wrap:wrap;gap:10px;align-items:center;margin-top:8px}
  .old{color:#b39b93;text-decoration:line-through}
  .discount{padding:4px 9px;border-radius:999px;background:#edf8f2;color:#357a57;font-size:.78rem;font-weight:800}
  .new{font-weight:800;color:var(--primary-deep)}
  .service-btn{min-width:126px;height:44px;border-radius:14px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:800;box-shadow:0 10px 22px rgba(201,112,89,.18)}
  .service-btn.added{background:#edf8f2;color:#357a57}
  .tab-wrap{position:sticky;top:18px;z-index:4;padding-top:18px;background:linear-gradient(180deg,rgba(255,253,251,1) 0%, rgba(255,253,251,.92) 78%, rgba(255,253,251,0) 100%)}
  .detail-tabs{display:flex;gap:10px;padding:10px}
  .tab-btn{padding:14px 18px;border-radius:16px;font-weight:800}
  .tab-panels{display:flex;flex-direction:column;gap:16px;padding-top:10px}
  .tab-panel{display:none;padding:22px}
  .tab-panel.active{display:block}
  .feature-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-top:16px}
  .feature-card{display:flex;gap:12px;align-items:center;padding:16px;border:1px solid var(--line-soft);border-radius:18px;background:#fffaf8;font-weight:700}
  .feature-card i{color:var(--primary-deep)}
  .hours-card{margin-top:18px;padding:18px;border-radius:20px;background:#fff7f2;border:1px solid var(--line-soft)}
  .hours-card h4{margin:0 0 12px}
  .hours-grid{display:grid;grid-template-columns:1fr auto;gap:10px 16px;color:var(--muted)}
  .reviews-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:16px}
.review-top{display:flex;align-items:center;gap:12px;margin-bottom:12px}
  .review-top img{width:56px;height:56px;border-radius:50%;object-fit:cover}
  .review-stars{margin-left:auto;padding:7px 10px;border-radius:999px;background:#fff3ee;color:var(--primary-deep);font-weight:800;white-space:nowrap}
  .review-card p{margin:0;color:var(--muted);line-height:1.6}
  .review-card small{color:var(--muted)}
  .portfolio-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:14px}
  .portfolio-grid img{width:100%;height:180px;object-fit:cover;border-radius:18px;border:1px solid var(--line-soft);cursor:pointer}
  .sidebar-right{position:sticky;top:18px;display:flex;flex-direction:column;gap:16px}
  .summary-card,.booking-card,.map-card{padding:18px}
  .meta-top{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}
  .badge{padding:8px 12px;border-radius:999px;font-weight:800}
  .badge.feature{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff}
  .badge.plain{background:#fff3ee;color:var(--primary-deep)}
  .summary-row{display:flex;justify-content:space-between;gap:12px;padding:12px 0;border-bottom:1px solid var(--line-soft);color:var(--muted)}
  .summary-row:last-child{border-bottom:none;padding-bottom:0}
  .booking-head{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;padding-bottom:14px;border-bottom:1px solid var(--line-soft)}
  .booking-head h3{margin:.2rem 0 0}
  .cart-count{min-width:36px;height:36px;border-radius:999px;background:#fff3ee;color:var(--primary-deep);font-weight:800;display:grid;place-items:center}
  .cart-list{display:flex;flex-direction:column;gap:12px;max-height:300px;overflow:auto;padding:14px 0}
  .empty-cart{padding:18px;border:1px dashed var(--line);border-radius:18px;background:#fffaf8;color:var(--muted);text-align:center}
  .cart-item{display:grid;grid-template-columns:56px minmax(0,1fr) auto;gap:12px;align-items:center;padding:12px;border:1px solid var(--line-soft);border-radius:18px;background:#fffaf8}
  .cart-item img{width:56px;height:56px;border-radius:14px;object-fit:cover}
  .cart-item h4{margin:0 0 4px;font-size:.96rem}
  .cart-item p{margin:0;color:var(--muted);font-size:.85rem}
  .remove-btn{height:38px;padding:0 12px;border-radius:12px;background:#fff2f0;color:var(--danger);font-weight:800}
  .cart-total{display:grid;grid-template-columns:1fr 1fr;gap:12px;padding:14px 0;border-top:1px solid var(--line-soft)}
  .cart-total div{padding:12px;border-radius:16px;background:#fff7f2;border:1px solid var(--line-soft)}
  .cart-total span{display:block;color:var(--muted);font-size:.85rem;margin-bottom:4px}
.map-preview{position:relative;min-height:220px;border-radius:20px;overflow:hidden;background:url('https://images.unsplash.com/photo-1524661135-423995f22d0b?auto=format&fit=crop&w=900&q=80') center/cover no-repeat}
  .map-preview::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,rgba(20,20,20,.05),rgba(20,20,20,.34))}
  .map-overlay{position:relative;z-index:1;height:100%;display:flex;flex-direction:column;justify-content:flex-end;gap:14px;padding:18px;color:#fff}
  .map-overlay p{margin:.35rem 0 0;color:rgba(255,255,255,.9)}
  .nearby{padding:22px;overflow:hidden}
.overlay-controls{display:flex;gap:10px}
  .circle-btn{width:42px;height:42px;border-radius:50%;background:#fff3ee;color:var(--primary-deep)}
  .nearby-slider{overflow:hidden;position:relative}
  .nearby-track{display:flex;gap:16px;transition:transform .35s ease}
  .near-card{min-width:calc(25% - 12px);border:1px solid var(--line-soft);border-radius:22px;background:#fffaf8;overflow:hidden}
  .near-card img{width:100%;height:190px;object-fit:cover}
  .near-body{padding:16px}
  .near-row{display:flex;justify-content:space-between;gap:10px;align-items:flex-start;margin-bottom:8px}
  .near-row h4{margin:0;font-size:1rem}
  .near-rating{padding:6px 9px;border-radius:999px;background:#fff3ee;color:var(--primary-deep);font-weight:800;white-space:nowrap}
  .near-body p{margin:0;color:var(--muted);line-height:1.55}
  .modal-backdrop,.sheet-backdrop{position:fixed;inset:0;background:rgba(37,24,20,.5);backdrop-filter:blur(3px);z-index:1000}
  .modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(92vw,620px);max-height:86vh;overflow:auto;background:#fff;border-radius:28px;box-shadow:0 30px 80px rgba(0,0,0,.18);z-index:1001}
  .modal-head{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;padding:22px 22px 16px;border-bottom:1px solid var(--line-soft)}
  .modal-body{padding:20px 22px 22px;display:flex;flex-direction:column;gap:18px}
  .selected-items{display:flex;flex-direction:column;gap:10px}
  .selected-row{display:flex;justify-content:space-between;gap:12px;padding:12px 14px;border-radius:16px;background:#fffaf8;border:1px solid var(--line-soft)}
  .modal-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
  .modal label{display:flex;flex-direction:column;gap:8px;font-weight:700}
  .modal input,.modal textarea{border:1px solid var(--line);background:#fffaf8;border-radius:16px;padding:14px;color:var(--text)}
  .payment-list{display:grid;grid-template-columns:1fr 1fr;gap:12px}
  .payment-option{display:flex;align-items:center;gap:12px;padding:16px;border-radius:18px;background:#fffaf8;border:1px solid var(--line-soft);font-weight:800}
  .payment-option input{accent-color:var(--primary)}
  .gallery-modal{position:fixed;left:50%;top:50%;transform:translate(-50%,-50%);width:min(94vw,1080px);height:min(88vh,760px);background:#13100f;border-radius:28px;z-index:1001;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px rgba(0,0,0,.34)}
  .gallery-modal img{flex:1;min-height:0;object-fit:contain;background:#13100f}
  .gallery-close{position:absolute;top:16px;right:16px;width:46px;height:46px;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;z-index:3}
  .gallery-nav{position:absolute;top:50%;transform:translateY(-50%);width:48px;height:48px;border-radius:50%;background:rgba(255,255,255,.14);color:#fff;z-index:3}
  .gallery-nav.prev{left:18px}.gallery-nav.next{right:18px}
  .gallery-strip{display:flex;gap:10px;padding:14px;background:#1a1513;overflow:auto}
  .gallery-thumb{width:82px;height:62px;border-radius:14px;overflow:hidden;border:2px solid transparent;cursor:pointer;opacity:.75;flex:0 0 auto}
  .gallery-thumb.active{border-color:#fff;opacity:1}
  .gallery-thumb img{width:100%;height:100%;object-fit:cover}
  .mobile-fab,.sheet{display:none}
  @media (max-width: 1199px){
    .desktop-layout{grid-template-columns:250px minmax(0,1fr) 290px}
    .service-browser{grid-template-columns:180px minmax(0,1fr)}
    .hero-slide{height:320px}
  }
  @media (max-width: 991px){
.topbar{flex-direction:column}
    .top-actions{justify-content:flex-start}
    .hero-slide{min-width:100%;height:280px}
    .hero-nav.prev{left:18px}.hero-nav.next{right:18px}
    .desktop-layout{grid-template-columns:1fr}
    .sidebar-left,.sidebar-right{display:none}
    .service-browser{grid-template-columns:1fr;max-height:none}
    .service-visual{position:relative;top:auto;min-height:220px}
    .services-scroll{max-height:none}
    .tab-wrap{position:static;padding-top:14px;background:none}
    .detail-tabs{overflow:auto}.detail-tabs::-webkit-scrollbar{display:none}
    .tab-btn{white-space:nowrap}
    .feature-grid,.reviews-grid,.portfolio-grid,.modal-grid,.payment-list,.cart-total{grid-template-columns:1fr}
    .portfolio-grid img{height:220px}
    .near-card{min-width:calc(50% - 8px)}
    .mobile-fab{display:inline-flex;align-items:center;justify-content:center;gap:10px;position:fixed;bottom:18px;z-index:80;padding:14px 18px;border-radius:999px;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;font-weight:800;box-shadow:0 16px 34px rgba(201,112,89,.28)}
    .filter-fab{left:16px}.booking-fab{right:16px}
    .sheet{display:flex;position:fixed;left:0;right:0;bottom:0;max-height:86vh;background:#fff;border-top-left-radius:28px;border-top-right-radius:28px;z-index:1001;flex-direction:column}
    .sheet-head{display:flex;justify-content:space-between;align-items:center;padding:18px 20px;border-bottom:1px solid var(--line-soft)}
    .sheet-body{padding:18px 20px 22px;overflow:auto}
  }
  @media (max-width: 767px){
    .title-meta{font-size:.86rem}
    .hero-slide{height:240px}
    .hero-thumb{width:62px;height:48px}
    .service-item{grid-template-columns:68px minmax(0,1fr);align-items:flex-start}
    .service-item img{width:68px;height:68px}
    .service-item .service-btn{grid-column:1/-1;width:100%}
    .cart-item{grid-template-columns:54px minmax(0,1fr)}
    .cart-item .remove-btn{grid-column:1/-1;width:100%}
    .near-card{min-width:100%}
    .gallery-modal{width:96vw;height:82vh}
    .gallery-strip{padding:10px}
  }


/* Final consistency overrides */
.site-header .container,.site-header .container-xxl,.site-footer .container,.site-footer .container-xxl{max-width:1440px}
.site-header{padding:18px 0 8px;background:linear-gradient(180deg,rgba(255,255,255,.92),rgba(255,255,255,.72));backdrop-filter:blur(16px)}
.header-shell{width:100%;max-width:100%;display:grid;grid-template-columns:auto minmax(260px,620px) auto;align-items:center;gap:18px;padding:14px 18px;background:var(--soft-bg);border:1px solid rgba(255,255,255,.7);border-radius:28px;box-shadow:var(--shadow)}
.pac-container{z-index:3000!important}
.brand-logo{background:linear-gradient(135deg,var(--secondary),var(--accent-2),var(--accent));color:#6f4a3d}
.explore-btn{background:linear-gradient(135deg,var(--secondary),var(--accent-2));color:#5a3d34}
.header-btn.primary-btn{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent;box-shadow:0 12px 24px rgba(201,112,89,.18)}
.menu-option-btn i,.category-icon,.feature-icon,.listing-rating,.review-stars,.social-links-row a,.footer-social-row a{color:var(--primary-deep)}
.footer-main-grid{background:linear-gradient(135deg,rgba(255,255,255,.92),rgba(255,247,243,.94));box-shadow:var(--shadow)}
.listing-card-body,.card-body{padding:18px}
.review-card{padding:24px;height:100%}
.review-card h3{margin:0 0 6px;font-size:1.1rem}
.review-card span{color:#74808f;font-size:.92rem}
@media (max-width:1199.98px){.header-shell{grid-template-columns:1fr;gap:14px}.header-center{order:3}.header-right{justify-content:space-between;flex-wrap:wrap}}
@media (max-width:767.98px){.header-shell{grid-template-columns:auto auto;align-items:center;padding:14px;border-radius:22px}.header-left{order:1}.header-right{order:2;justify-self:end;justify-content:flex-end;width:auto}.header-center{order:3;grid-column:1/-1}.header-right>.header-btn{display:none}.menu-toggle-btn{flex:0 0 auto;min-width:auto;padding:12px 16px}.menu-toggle-btn span{display:none}.header-dropdown-menu{right:0;top:calc(100% + 12px);width:min(320px,calc(100vw - 38px))}.category-strip-wrap,.hero-card,.listing-card,.feature-box,.review-card,.offer-banner-card{border-radius:22px}}


/* ==== fix: unified tabs + booking modal ==== */
.tab-wrap{
  width:100%;
  overflow:hidden;
}
.detail-tabs{
  display:flex;
  flex-wrap:nowrap;
  align-items:center;
  width:100%;
}
.detail-tabs .tab-btn,
.tab-btn{
  width:auto !important;
  flex:0 0 auto;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  white-space:nowrap;
  max-width:max-content;
}

.modal-backdrop{
  display:block;
  opacity:1;
  visibility:visible;
}
.modal{
  display:block;
  opacity:1;
  visibility:visible;
  position:fixed !important;
  left:50%;
  top:50%;
  transform:translate(-50%,-50%);
  z-index:2001;
  margin:0;
}
.modal-backdrop{
  z-index:2000;
}
.modal.hidden,
.modal-backdrop.hidden{
  display:none !important;
}

@media (max-width: 767.98px){
  .detail-tabs{
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
  }
  .detail-tabs .tab-btn,
  .tab-btn{
    min-width:max-content;
  }
  .modal{
    width:min(94vw,620px);
    max-width:94vw;
  }
}
